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TITLE OF THE INVENTION 
IMAGE INPUT APPARATUS AND CONTROL METHOD THEREFOR 

FIELD OF THE INVENTION 
5 The present invention relates to an image input 

apparatus and a control method therefor and, more 
particularly, to an image input apparatus for 
compressing a scanned image and storing it and a 
control method for the apparatus. 

10 

BACKGROUND OF THE INVENTION 

The advent of multi-function copying machines, 
network scanners, and printers has made it possible to 
freely exchange images with computers through networks. 

15 These devices generally use image compression 

techniques to reduce the load on the networks. In 
recent years, irreversible JPEG compression is often 
used as an image compression technique for multilevel 
images (color images) . In this compression method, 

20 however, the amount of compressed data cannot be known 
before all the image data is actually compressed. This 
technique is therefore supposed to be inappropriate to 
a scanning system for compressing an image in real time 
because it cannot be known whether the image data can 

2 5 be completely stored in an image memory prepared in 
advance . 
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In another method, even when compressed data is 
larger in size than the memory capacity ensured to hold 
the image and cannot be completely stored, that amount 
of compressed data is measured, the necessary memory 
capacity is ensured, and then, scanning is performed 
for the second time to obtain image data. However, if 
the measured amount of compressed data exceeds the 
available memory capacity, the image cannot be acquired. 

SUMMARY OF THE INVENTION 
The present invention has been made in 
consideration of the above situation, and has as its 
object to, in reading, compressing, and storing an 
image in a storage medium such as a memory, more 
reliably store the whole compressed image data in the 
second scanning even when an error occurs during the 
first scanning. 

According to the present invention, the foregoing 
object is attained by providing a control method for an 
image input apparatus for reading an original and 
compressing image data of the read original in real 
time, the method comprising: a memory area ensuring 
step of ensuring a memory area for storing compressed 
image data; a read step of reading an original and 
outputting image data; a compression step of 
compressing the image data in real time; a storage step 



of storing the compressed image data in the memory area 
ensured in the memory area ensuring step; a 
determination step of determining whether the 
compressed image data is completely stored in the 
5 memory area; a compression ratio change step of, when 
it is determined in the determination step that the 
image data is not completely stored, changing a 
compression ratio in the compression step; and a repeat 
step of, when the compression ratio is changed in the 

10 compression ratio change step, controlling to repeat 
the read step, the compression step, and the storage 
step using the changed compression ratio. 

According to the present invention, the foregoing 
object is attained by providing a control method for an 

15 image input apparatus for reading an original and 

compressing image data of the read original in real 
time, the method comprising: 

a memory area ensuring step of ensuring a memory area 
for storing compressed image data; a read step of 

20 reading an original and outputting image data; a 

compression step of compressing the image data in real 
time; a storage step of storing the compressed image 
data in the memory area ensured in the memory area 
ensuring step; a determination step of determining 

25 whether the compressed image data is completely stored 
in the memory area; a resolution change step of, when 
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it is determined in the determination step that the 
image data is not completely stored, changing a 
resolution in the read step; and a repeat step of, when 
the resolution is changed in the resolution change step, 
5 controlling to repeat the read step, the compression 

step, and the storage step using the changed resolution. 

Further, the foregoing object is also attained by 
providing an image input apparatus comprising: memory 
area ensuring means for ensuring a memory area for 

10 storing compressed image data; read means for reading 
an original and outputting image data; compression 
means for compressing the image data in real time; 
storage means for storing the compressed image data in 
the memory area ensured by the memory area ensuring 

15 means; determination means for determining whether the 
compressed image data is completely stored in the 
memory area; compression ratio change means for, when 
it is determined by the determination means that the 
image data is not completely stored, changing a 

20 compression ratio used by the compression means; and 
control means for, when the compression ratio is 
changed by the compression ratio change means, 
controlling to repeat the read of the original using 
the changed compression ratio. 

25 Further, the foregoing object is also attained by 

providing an image input apparatus comprising: memory 



area ensuring means for ensuring a memory area for 
storing compressed image data; read means for reading 
an original and outputting image data; compression 
means for compressing the image data in real time; 
5 storage means for storing the compressed image data in 
the memory area ensured by the memory area ensuring 
means; determination means for determining whether the 
compressed image data is completely stored in the 
memory area; resolution change means for, when it is 

10 determined by the determination means that the image 
data is not completely stored, changing a resolution 
used by the read means; and control means for, when the 
resolution is changed by the resolution change means, 
controlling to repeat the read of the original using 

15 the changed resolution. 

Other features and advantages of the present 
invention will be apparent from the following 
description taken in conjunction with the accompanying 
drawings, in which like reference characters designate 

20 the same or similar parts throughout the figures thereof. 



BRIEF DESCRIPTION OF THE DRAWINGS 
The accompanying drawings, which are incorporated 
in and constitute a part of the specification, 
25 illustrate embodiments of the invention and, together 
with the description, serve to explain the principles 
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of the invention. 

Fig. 1 is a diagram showing an example of the 
configuration of a network system to which an image 
input/output apparatus according to an embodiment of 
5 the present invention is connected; 

Fig. 2 is a block diagram illustrating the 
overall structure of the image input/output apparatus 
according to the embodiment of the present invention; 

Fig. 3 is an external view of the image 
10 input /output apparatus, shown in Fig. 2, seen from the 
side according to the embodiment of the present 
invention; 

Fig. 4 is a diagram showing the external 
appearance of a control panel of the image input/output 
15 apparatus according to the embodiment of the present 
invention; 

Fig. 5 is a block diagram illustrating the 
configuration of a scanner image processor according to 
the embodiment of the present invention; 
20 Fig. 6 is a block diagram illustrating the 

configuration of a printer image processor according to 
the embodiment of the present invention; 

Fig. 7 is a block diagram illustrating the 
configuration of an image compression/expansion unit 
25 according to the embodiment of the present invention; 

Fig. 8 is a block diagram illustrating the 



configuration of an image rotation processor according 
to the embodiment of the present invention; 

Fig. 9 is an explanatory view of image rotation 
processing; 

5 Fig. 10 is an explanatory view of image rotation 

processing; 

Fig. 11 is a block diagram illustrating the 
configuration of a device interface according to the 
embodiment of the present invention; 

10 Fig. 12 is a block diagram showing the overall 

configuration of software installed in the image 
input/output apparatus according to the embodiment of 
the present invention; 

Fig. 13 is a block diagram illustrating a 

15 configuration of built-in applications of the present 
invention; 

Fig. 14 is a diagram showing an operation image 

displayed on the control panel according to the 

embodiment of the present invention; 
20 Fig. 15 is a diagram showing the connection 

relationship between a DIS and a job manager, print 

manager and scan manager; 

Fig. 16 is a diagram showing a database and a 

counter within the DIS; 
25 Fig. 17 is a block diagram showing software 

control in scanning; 



Fig. 18 is a diagrammatic view a parameter table 
in used in scanning; 

Fig. 19 is a timing chart showing transfer timing 
of print image data; 
5 Fig. 20 is a diagram showing a print parameter 

matrix in an engine interface board; 

Fig. 21 is a diagram showing communication 
commands between a printer and the engine interface- 
board; 

10 Fig. 22 is a block diagram showing the detailed 

arrangement of a JPEG compression unit in the first 
embodiment of the present invention; 

Fig. 23 is a flow chart showing the operation of 
a codec manager in the first embodiment of the present 
15 invention; 

Fig. 24 is a flow chart showing the operation of 
a scan-sequence control unit in the first embodiment of 
the present invention; 

Fig. 25 is a table related to JPEG compression 
2 0 settings; 

Fig. 26 is a flow chart showing the operation of 
a scan-sequence control unit in the second embodiment 
of the present invention; 

Fig. 27 is a view showing a resolution setting 
25 window in scanning where JPEG compression is executed 
in real time in the second embodiment of the present 



invention; 

Fig. 28 is a flow chart showing the operation of 
a scan-sequence control unit in the third embodiment of 
the present invention; and 
5 Fig. 29 is a view showing a control unit setting 

window in scanning where JPEG compression is executed 
in real time in the third embodiment of the present 
invention. 

10 DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

Preferred embodiments of the present invention 
will be described in detail in accordance with the 
accompanying drawings. 
<Overall System> 

15 Fig. 1 is a block diagram illustrating an example 

of the configuration of a network system to which an 
image input apparatus of this invention is connected. 
Reference numeral 1001 denotes an image input /output 
apparatus comprising a scanner, an image input 

20 apparatus of the present invention and printer. An 

image read in from the scanner can be sent to a local 
area network (LAN) 1010, and an image received from the 
LAN 1010 can be printed out by the printer. Further, 
an image read in from the scanner can be transmitted by 

25 facsimile transmission means (not shown) to a facsimile 
apparatus 1031 via a PSTN or ISDN 1030, and an image 



received via the PSTN or ISDN can be printed out by the 
printer . 

A database server 1002 manages binary images and 
multilevel images, which have been read in by the 
5 input/output apparatus 1001, as a database. A database 
client 1003 of the database server 1002 is capable of 
browsing/retrieving image data that has been stored in 
the database 1002. An electronic mail server 1004 is 
capable of receiving an image, which has been read by 

10 the image input /output apparatus 1001, as an attachment 
to e-mail. An electronic mail client 1005 is capable 
of receiving and browsing mail that has been accepted 
by the e-mail server 1004, and of transmitting e-mail. 
A WWW server 1006 supplies the LAN with HTML text. 

15 HTML text provided by the WWW server 1006 can be 
printed by the image input/output apparatus 1001. 
Reference numeral 1007 denotes a DNS (Domain Name 
Server) . A router 1011 connects the LAN 1010 to the 
Internet or to an intranet 1012. Devices similar to 

20 the image input/output apparatus 1001, database server 
1002, WWW server 1006 and electronic mail server 1004 
are connected to the Internet/intranet as devices 1020, 
1021, 1022, and 1023. Further, a printer 1040 is 
connected on the LAN 1010 and is capable of printing 

25 out images read by the image input/output apparatus 
1001. 
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<Conf iguration of the Image Input/Output Apparatus> 

Next, a configuration of the image input/output 
apparatus 1001 will be explained. 

First, the overall structure of the input/output 
5 apparatus 1001 is explained with reference to Fig. 2. 
Referring to Fig. 2, the apparatus includes a 
controller 2000, control panel 2012 serving as a user 
interface (UI) , a scanner 2070 serving as an image 
input device and a printer 2095 serving as an image 

10 output device. 

By being connected to the scanner 2070 and the 
printer 2095 as well as the LAN 1010 or public circuit 
(WAN) 2051, the controller 2000 is capable of 
controlling input and output of image information and 

15 device information. A CPU 2001 is a controller for 
controlling the overall apparatus. A RAM 2002 is a 
system working memory for operation of the CPU 2001. 
This acts as an image memory for storing image data 
temporarily. A ROM 2003 is a booting ROM in which the 

20 booting program of the system has been stored. A hard- 
disk drive (HDD) 2004 stores the system software and 
image data. A control-panel interface (I/F) 2006, 
which is for interfacing the control panel 2012, 
outputs image data to be displayed on the control panel 

25 2012 to the control panel 2012. Another function of 
the control panel 2012 is to send the CPU 2001 



information that the user of the system has entered 
from the control panel. A modem 2050 is connected to 
the public circuit 2051 and serves to input and output 
information. Further,, a network interface 2010 is 
5 connected to the LAN 1010 and serves to input and 

output information. The devices mentioned above are 
disposed on a system bus 2007. 

An image bus interface 2005 is a bus bridge for 
connecting the system bus 2007 and an image bus 2008, 

10 which transfers image data at high speed, and for 
converting the data structure. 

The image bus 2008 is constituted by a PCI bus or 
IEEE 1394. The devices set forth below are disposed on 
the image bus 2008. 

15 A raster image processor (RIP) 2060 expands PDL 

(Page Description Language) code into a bitmap image. 
A device interface <I/F) 2020 connects the scanner 2070 
and printer 2095 to the controller 2000 and subjects 
the image data to a synchronous/asynchronous conversion. 

20 A scanner image processor 2080 subjects input image 

data, read by the scanner 2070 and input via the device 
I/F 2020, to correction, manipulation and editing. A 
printer image processor 2090 subjects image data to be 
output from the printer to correction and resolution 

25 conversion, etc. in correspondence with the printer. 
An image rotation processor 2030 rotates image data. 



An image compression/expansion unit 2040 subjects 
multilevel image data to JPEG compression/decompression 
processing and subjects binary image data to JBIG, MMR 
or MH compression/expansion processing. 
5 The arrangement described above is constructed in 

such a manner that configuration elements that connect 
to the system bus 2007 and configuration elements that 
connect to image bus 2008 are separable from each other 
taking into consideration expandability of the image 

10 processors. The structure of an ordinary computer is 
adopted. Making the image bus interface 2005 a 
general-purpose interface provides a degree of freedom 
that makes it possible to combine image processing 
operations at will and also affords expandability for 

15 future applications. In particular, the CODEC section 
(image compression/expansion unit 2040) is connected to 
the side of the image bus for easy interchangeability 
in view of the possibility that various standards may 
be announced in the future. 

20 Fig. 3 is a side view showing the external 

appearance of the image input/output apparatus 1001. 

The scanner 2070, which is the image input device, 
illuminates a document and scans the document using a 
CCD line sensor (not shown) to convert the scanned 

25 image into an electric signal representing raster-image 
data. The document is placed on a tray 2073 of an 
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image feeder 2072. When the user of the apparatus uses 
the control panel 2012 to instruct the apparatus to 
start reading the document, the CPU 2001 of the 
controller 2000 applies a command to the scanner 2070. 
5 The feeder 2072 feeds in the document one sheet at a 
time so that the document images are read. 

The printer 2095 serving as the image output 
device visualizes (prints) the raster-image data on a 
recording medium such as paper. Any printing technique 

10 may be used in the printer. Examples are 

electrophotography, which employs a photosensitive drum 
or belt, or an ink-jet technique, which forms an image 
directly on paper by jetting ink from an array of 
micronozzles . The printing operation is started up in 

15 response to a command from the CPU 2001. The printer 
2095 possesses a plurality of supply bins that make it 
possible to select printing media of different sizes or 
orientations, as well as cassettes 2101, 2102, 2103 and 
2104 corresponding to these bins. A drop tray receives 

20 the printing medium on which printing has been 
completed. 

The control panel 2012 is located at a position 
where the user can easily observe, and an example of 
the external appearance is shown in Fig. 4. An LCD 
25 display unit 2013 includes a touch-sensitive panel 
affixed to a liquid crystal display and displays a 



screen for operating the system. Further, if displayed 
keys are pressed, the corresponding position 
information is sent to the controller CPU 2001. A 
start key 2014 is used to start the reading of a 
5 document image. Provided at the center of the start 
key 2014 is a two-color (green and red) LED 2018 the 
color of which indicates whether the start key 2014 is 
operable. A stop key 2015 is for halting an operation 
that is currently in progress. An ID key 2016 is used 

10 when the user inputs a user ID. A reset key 2017 is 
used to initialize settings from the control panel. 

Next, the configuration elements of the 
controller 2000 will be explained. 
(Scanner Image Processor) 

15 Fig. 5 shows the construction of the scanner 

image processor 2080. An image bus interface 
controller 2081 connects to the image bus 2008 and 
controls the bus access sequence, generates timing and 
controls each device within the scanner image processor 

20 2080 with a control signal (CTL) . A filter processor 

2082 is a spatial processor for executing a convolution 
operation on an input image data (IM) . An editing unit 

2083 recognizes a closed area, namely an area that has 
been enclosed by a marker pen, from the input image 

25 data, and subjects the image data in this closed area 
to image manipulation processing such as shadowing, 



- 15 - 



hatching and negative-positive reversal. 

A scaling processor 2084 performs enlargement and 
reduction by executing interpolation in the main-scan 
direction of the raster image in a case of changing 
5 resolution of the read image. With regard to 

enlargement and reduction in the sub-scan direction, 
this is carried out by changing the moving speed of the 
image reading line sensor (not shown) in the sub-scan 
direction; therefore, the scaling processor 2084 does 

10 not perform enlargement and reduction in the sub-scan 
direction. A table converter 2085 uses a table to 
convert image data, which is read luminance data, to 
density data. A binarizing processor 2086 binarizes 
multilevel grayscale image data by error-diffusion 

15 processing or screen processing. JPEG compression unit 
2087 performs real-time compressing on the multilevel 
image data output from the table using known JPEG 
compression. Code data encoded by JPEG coding is 
output from the JPEG compression unit 2087. Image data 

20 the processing of which has been completed is 

transferred on the image bus again via the image bus 
interface controller 2081. 

(Printer Image Processor) 

Fig. 6 shows the construction of the printer 
25 image processor 20 90. An image bus interface 

controller 2091 connects to the image bus 2008 and 
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controls the bus access sequence, generates timing and 
controls each device within the printer image processor 
2090 with a control signal (CTL) . A resolution 
converter 2092 executes a resolution conversion to 
5 convert the resolution of image data (IM), which has 
been received from the LAN 2011 or WAN 2051, to the 
resolution of the printer 2095. A smoothing processor 
2093 executes processing so as to smoothen jaggies 
(jaggedness which appears at edges of diagonal lines 

10 and the like) after the resolution conversion. 
(Image Compression/Expansion Unit) 
Fig. 7 shows the construction of the image 
compression/expansion unit 204 0. An image bus 
interface controller 2041 connects to the image bus 

15 2008 and controls the bus access sequence, controls 

timing for performing an exchange of data with an input 
buffer 2042 and output buffer 2045 and controls a mode 
setting with regard to an image compressor/expander 
2043. Processing executed by the image 

20 compression/expansion unit 2040 will now be described. 

The image bus interface controller 2041 is set up 
for image compression/expansion control from the CPU 
2001 via the image bus 2008. In accordance with this 
set up, the image bus interface controller 2041 

25 subjects the image compressor/expander 2043 to a 
setting necessary for image compression and 
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expansion (e . g . , MMR compression, JBIG expansion, etc.). 
After the necessary set-up is made, the CPU 2001 
permits the image bus interface controller 2041 to 
transfer image data again. In accordance with such 
5 permission, the image bus interface controller 2041 
starts receiving of image data from the RAM 2002 or 
from each device on the image bus 2008. 

The image data received is stored temporarily - in 
the input buffer 2042 and the image is transferred at a 

10 fixed speed in conformity with the image data 

requirement of the image compressor/expander 2043. At 
this time the input buffer 2042 determines whether the 
image data can be transferred between the image bus 
interface controller 2041 and the image 

15 compressor /expander 2043. In a case where it is 

impossible to read image data from the image bus 2008 
and to write image data to the image 
compressor/expander 2043, the input buffer 2042 
exercises control in such a manner that data is not 

20 transferred (such control is referred to as "handshake 
control" ) . 

The image compressor /expander 2043 stores the 
received image data in the RAM 2044 temporarily. The 
reason for this is that several lines of data are 
25 required, depending upon the type of image compression 
or expansion processing to be executed, when image 
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compression is carried out. For insatance, if several 
lines of data are required for compressing/expading the 
first single line, image compression of the initial 
line cannot be carried out unless several lines of 
5 image data are prepared in the RAM 2044 . The image 
data that has undergone compression or expansion is 
sent to the output buffer 2045 immediately. 

Handshaking between the image bus interface 
controller 2041 and the image compressor/expander 2043 

10 takes place in the output buffer 2045, which then 

transfers the image data to the image bus interface 
controller 2041. The latter transfers this transferred 
and compressed (or expanded) image data to the RAM 2002 
or to each device on the image bus 2008. This series 

15 of processes is repeated until there are no longer any 
processing requests from the CPU 2001 (which occurs 
when processing of the required number of pages has 
ended) or until there is a halt request from the image 
compressor/expansion unit 2040 (as when an error occurs 

20 at the time of compression or expansion) . 
(Image Rotation Processor) 

Fig. 8 illustrates the construction of the image 
rotation processor 2030. An image bus interface 
controller 2031 connects to the image bus 2008 and 
25 controls the bus access sequence, controls the mode, 
etc., to which an image rotator 2032 is set, and 



controls timing for the transfer of image data to the 
image rotator 2032. The processing executed by the 
image rotator 2032 will now be described. 

The image bus interface controller 2031 is set up 
5 for image rotation control from the CPU 2001 via the 
image bus 2008. In accordance with this set up, the 
image bus interface controller 2031 subjects the image 
rotator 2032 to settings necessary for image rotation 
(e.g., image size, direction and angle of rotation, 

10 etc., are set). After the necessary settings are made, 
the CPU 2001 permits the image bus interface controller 
2031 to transmit the image data. In accordance with 
such permission, the image bus interface controller 
2031 starts the reception of image data from the RAM 

15 2002 or from each device on the image bus 2008. It is 

assumed that the width of the image bus 2008 is 32 bits, 
that the size of the image to be rotated is 32 x 32 
bits, and that when the image data is transferred on 
the image bus 2008, the image transfer is made in units 

20 of 32 bits. (The image is assumed to be binary image.) 

In order to thus obtain an image of 32 x 32 bits, 
the above-mentioned transfer in 32-bit units must be 
executed 32 times and it is required that the image 
data be transferred from non-contiguous addresses (see 

25 Fig. 9). The image data transferred by non-contiguous 
addressing is written to the RAM 2033 in such a manner 



that it will be rotated through the desired angle when 
it is read out. For example, if rotation is 90° in the 
counter-clockwise direction, the initially transferred 
32-bit image data is written in the Y direction in the 
5 manner shown in Fig. 10. At read-out, the image data 
is read out in the X direction, whereby the image is 
rotated. 

Upon completion of 32 x 32 - bit image rotation 
(writing to the RAM 2033), the image rotator 2032 reads 

10 the image data out of the RAM 2033 through the above- 
described method and transfers the image to the image 
bus interface controller 2031. 

The image bus interface controller 2031 that has 
received the rotated image data transfers the data to 

15 the RAM 2002 or to each device on the image bus 2008 
through contiguous addressing. This series of 
processes is repeated until there are no longer any 
processing requests from the CPU 2001 (which occurs 
when processing of the required number of pages has 

20 ended), or until there is a halt request from the image 
rotation processor 2030 (as when an error occurs at the 
time of rotation) . 

(Device Interface) 

Fig. 11 illustrates the construction of the 
25 device interface 2020. An image bus interface 

controller 2021 connects to the image bus 2008 and 



controls the bus access sequence, controls each device 
in the device interface 2020 and generates timing. In 
addition, the image bus interface controller 2021 
generates control signals applied to the external 
5 scanner 2070 and printer 2095. A scan buffer 2022 

temporarily stores the image data sent from the scanner 
2070 and outputs the synchronized image data to the 
image bus 2008. 

The image data that has been stored in the scan 

10 buffer 2022 is placed in numerical order or 

disassembled by a serial-parallel/parallel-serial 
converter 2023, whereby there is achieved a conversion 
to a data width of image data capable of being 
transferred to the image bus 2008. Image data that has 

15 been transferred from the image bus 2008 is decomposed 
or placed in numerical order by a parallel- 
serial/serial-parallel converter 2024, whereby there is 
achieved a data width of image data capable of being 
stored in a print buffer 2025. The print buffer 2025 

20 temporarily stores image data sent from the image bus 
2008 and outputs the synchronized image data to the 
printer 2095. 

Processing at the time of image scanning will now 
be described. 

25 Image data sent from the scanner 2070 is stored 

in the scan buffer 2022 in sync with a timing signal 
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sent from the scanner 2070. If, in a case where the 
image bus 2008 is a PCI bus, image data in excess of 32 
bits has entered the buffer, 32 bits of the image data 
is sent from the buffer to the serial- 
5 parallel/parallel-serial converter 2023 in first-in 

first-out fashion, the data is thereby converted to 32- 
bit image data and the image data is transferred on the 
image bus 2008 through the image bus interface 
controller 2021. Further, in a case where the image 

10 bus 2008 is in compliance with IEEE 1394, the image 
data in the scan buffer 2022 is sent from the scan 
buffer 2022 to the serial-parallel/parallel-serial 
converter 2023 in first-in first-out fashion, the data 
is thereby converted to serial image data and the 

15 serial image data is transferred on the image bus 2008 
through the image bus interface controller 20'21. 

Processing at the time of image printing will now 
be described. 

In a case where the image bus 2008 is a PCI bus, 

20 32-bit image data sent from the image bus 2008 is 

received by the image bus interface controller 2021, 
sent to the parallel-serial/serial-parallel converter 
2024, disassembled into image data having the number of 
bits that can be input to the printer 2095 and then 

25 stored in the print buffer 2025. In a case where the 
image bus 2008 is in compliance with IEEE 1394, serial 



image data sent from the image bus 2008 is received by 
the image bus interface controller 2021, sent to the 
parallel-serial/serial-parallel converter 2024, 
converted to image data having the number of bits that 
5 can be input to the printer 2095 and then stored in the 
print buffer 2025. Then, in sync with a timing signal 
sent from the printer 2 0 95, the image data in the 
buffer 2095 is sent to the printer 2095 in first-in" 
first-out fashion. 

10 <Software> 

(Overall Structure of Software Block) 
Fig. 12 is a block diagram showing the modular 
structure of the software installed in the image 
input/output apparatus 1001 to which the present 

15 invention is applied. 

A module 1501, which controls the UI (user 
interface) , acts as the intermediary with the image 
input/output apparatus lOOlwhen a user performs various 
operation and settings on the apparatus 1001. This 

20 module transfers input information, requests to execute 
processes, and setting data in various modules, 
described later. 

An address book module 1502 is a database module 
for managing the addressee and communication 

25 destination of data. Data can be added to, deleted 

from and acquired from the address book by an operation 
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performed at the UI 1501, and the address book is used 
as means for providing each module (described below) 
with data address and communication-destination 
information in response to an operation performed by 
5 the operator. 

A Web-server module 1503 is used to notify 
management information of the image input/output 
apparatus 1001 in response to a request from a Web 
client (not shown) . The management information is 

10 acquired via a control API 1518 (described later) and 
notified to the Web client via an HTTP module 1512, 
TCP/IP communication module 1516 and network driver 
1517, described later. 

A universal-send module 1504 controls the 

15 distribution of data. Data that has been designated by 
the operator using the UI 1501 is distributed to a 
communication (output) destination designated by the 
operator in similar fashion. In a case where the 
generation of data to be distributed using the scanner 

20 function of the image input/output apparatus 1001 has 
been designated by the operator, the apparatus 1001 
controls the scanner 2070 to operate via the control 
API 1518 (described later) and generates the data. 
A module 1505 is run when the printer is 

25 designated within the universal-send module 1504 as the 
output destination; a module 150 6 is run when an e-mail 
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address is designated within the universal-send module 
1504 as the communication destination; a module 1507 is 
run when a database is designated within the universal- 
send module 1504 as the output destination; and a DP 
5 module 1508 is run when an integrated apparatus similar 
to the apparatus 1001 is designated within the 
universal-send module 1504 as the output destination. 

A remote copy/scan module 1509, which uses the 
scanner 2070 of the image input/output apparatus 1001 

10 to read an image, adopts another integrated apparatus 
connected by a network or the like as the output 
destination, thereby executing processing the same as 
that of the copy function implemented by the image 
input/output apparatus 1001. A remote copy/print 

15 module 1510, which uses the printer 2095 of the image 
input/output apparatus 1001 to print an input image, 
adopts another integrated apparatus connected by a 
network or the like as the input source, thereby 
executing processing the same as that of the copy 

20 function implemented by the image input/output 
apparatus 1001. 

A Web-pull print module 1511 reads out and prints 
various web-page information from the Internet or 
intranet . 

25 A module 1512 is used when the image input/output 

apparatus 1001 communicates by HTTP. This module 1512 
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provides the Web-server module 1503 and Web-pull print 
module 1511 with communication by means of the TCP/IP 
communication module 1516, described below. 

An Ipr module 1513 provides the printer module 
5 1505 within the universal-send module 1504 with 

communication by means of the TCP/IP communication 
module 1516. 

An SMTP module 1514 provides the e-mail module 
1506 within the universal-send module 1504 with 
10 communication by means of the TCP/IP communication 
module 1516. 

A salutation manager (SLM) module 1515 provides 
the database (DB) module 1507, DP module 1508 within the 
universal-send module 1504 and the remote copy/scan 
15 module 1509 and remote copy/print module 1510 with 
communication by means of the TCP/IP communication 
module 1516. 

The TCP/IP communication module 1516 provides the 
above-mentioned modules with network communication by 
20 the network driver 1517. 

The network driver 1517 is for controlling 
components physically connected to the network. 

The control API 1518 interfaces modules upstream 
of the universal-send module 1504 with modules 
25 downstream of a job manager module 1519 (described 
later) , etc. The control API 1518 reduces the 
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dependency between the upstream and downstream modules 
and enhances the versatility of these modules. 

The job manager module 1519 interprets processes 
specified by the various modules via the control API 
5 1518 and applies commands to modules set forth below. 
These modules implement unified management of the 
hardware processes executed within the image 
input/output apparatus 1001. 

A CODEC manager module 1520 manages and controls 

10 various types of compression and expansion among the 

processes specified by the job manager module 1519. An 
FBE encoder 1521 compresses, in accordance with an FBE 
format, data read in by scanning processing executed by 
the job manager module 1519 and a scan manager module 

15 1524. A JPEG CODEC module 1522 performs JPEG 

compression of read data and JPEG expansion of print 
data in the scan processing executed by the job manager 
module 1519 and scan manager module 1524 and print 
processing executed by a print manager module 1526. An 

20 MMR CODEC module 1523 performs MMR compression of read 
in data and MMR expansion of print data in the scan 
processing executed by the job manager module 1519 and 
scan manager module 1524 and print processing executed 
by a print manager module 1526. 

25 The scan manager module 1524 manages and controls 

scan processing designated by the job manager module 



1519. A scanner driver 1525 is for implementing 
communication between the scan manager module 1524 and 
a scanner unit to which the image input/output 
apparatus 1001 is internally connected. 
5 The print manager module 152 6 manages and 

controls print processing designated by the job manager 
module 1519. A printer driver 1527 is for interfacing 
the print manager module 1526 and the printer 2095. ~ 
A parallel-port driver 1528 provides the 
10 interface when the Web-pull print module 1511 outputs 
data to an output device (not shown) via a parallel 
port . 

(Applications) 

An embodiment of built-in applications according - 
15 to the present invention will now be described with 
reference to the drawings. Fig. 13 is a diagram 
showing built-in application blocks, which relate to 
image-data distribution of the present invention. 

The blocks include an application block 4050 of 
20 the control panel 2012 which is explained with 
reference to Fig. 4; an application block 4100 
indicative of the transmitting side of a remote copy 
application; an application block 4150 indicating the 
transmitting side of broadcast distribution; an 
25 application block 4200 indicative of the Web pull print 
module; an application block 4250 indicative of the Web 



server module; an application block 4300 indicative of 
the receiving side (printing side) of the remote copy 
application; an application block 4350 for receiving 
and printing, by a general-purpose printer such as a 
5 laser beam printer (LBP) , an image that has been 

transmitted by broadcast distribution; an application 
block 4400 indicative of the receiving side (printing 
side) of remote printing; an application block 4450- for 
receiving and storing an image, which has been 

10 transmitted by broadcast transmission, by a well-known 
Notes (registered trademark) server; an application 
block 4500 for receiving and storing a binary image 
that has been transmitted by broadcast distribution; an 
application block 4550 for receiving and storing an 

15 image, which has been transmitted by broadcast 

distribution, by a well-known mail server; and an 
application block 4600 for receiving and storing a 
multilevel image that has been transmitted by broadcast 
distribution. A well-known Web server 4650 includes 

20 information content, and a well-known Web browser 4700 
accesses the Web server, etc. 

The each application block will now be described 
in detail. 

«UI Application» 

25 The user ' interface (UI) 1501 is as set forth 

earlier with reference to Fig. 12, and the address book 



1502 will be discussed here. The address book 1502 is 
preserved in a non-volatile storage device (non- 
volatile memory or hard disk, etc.) within the image 
input/output apparatus 1001 of the present invention. 
The features of the devices connected to the network 
are written in the address book 1502. The following 
items are set forth included in the address book 1502: 
the formal names and aliases of the devices; 
the network addresses of the devices; 
the network protocols capable of being executed 
by the devices; 

the document formats capable of being implemented 
by the devices; 

the types of compression capable of being 
executed by the devices; 

the image resolutions of the devices; 
the paper sizes capable of being supplied and 
information concerning the paper supply bins in case of 
a printer; and 

the names of folders capable of storing documents 
in case of a server (computer) . 

The applications described below are such that 
the features of distribution destinations are 
identified by information that has been written in the 
address book 1502. 

Further, the address book 1502 is capable of 



being edited and makes it possible to download and use 
what has been stored in the server computer in the 
network or to refer to this information directly. 
«Remote Copy Application» 
5 The remote copy application identifies, from the 

address book 1502, information representing resolution 
achievable by the device specified as the distribution 
destination, compresses the binarized image, which has 
been read by the scanner in accordance with the 

10 resolution information, using well-known MMR 

compression, converts the format of the compressed 
image to the well-known TIFF (Tagged Image File Format) 
and then transmits the image to the printer on the 
network via the SLM 1515. Though the SLM 1515 will not 

15 be described in detail, suffice it to say that it is 
one type of network protocol that includes device 
control information, etc., and is referred to as a 
Salutation Manager (or Smart-Link Manager) . 

«Broadcast Distribution Application» 

20 The broadcast distribution application differs 

from the remote copy application in that this 
application makes it possible to simultaneously 
transmit an image, obtained by a single image scan, to 
a plurality of distribution addresses. In addition, 

25 distribution destinations are not limited to image 
output devices such as printers; information can be 



distributed directly to so-called server computers as 
well. 

Operation will be described in accordance with 
the distribution destinations. 
5 If it is determined from the address book 1502 

that the device which is the distribution destination 
is capable of implementing well-known LIPS functions as 
printer control commands in accordance with LPD (Line 
Printer Daemon) , which is a well-known network printer 

10 protocol, then an image is read in accordance with the 
image resolution similarly determined from the address 
book 1502, the image itself is compressed using well- 
known FBE (First Binary Encoding) in this embodiment, 
the compressed image is further converted to LIPS codes 

15 and the codes are transmitted to the device at the 
destination by LPR, which is a well-known network 
printer protocol. 

If the destination device of distribution is 
capable of communicating in accordance with SLM and is 

20 a server device, the server address and the designation 
of the folder within the server are determined from the 
address book 1502. Then, in a manner similar to that 
of the remote copy application, the binary image, which 
has been read by the scanner, can be compressed using 

25 well-known MMR ' compression, the format of the 

compressed image can be converted to the TIFF (Tagged 



Image File Format) and the image can be stored in a 
specific folder of the server device on the network via 
SLM 1515. 

The apparatus of this embodiment is such that if 
5 the server, as the destination device, is determined to 
be capable of processing a multilevel image that has 
undergone JPEG compression, then, in a manner similar 
to that of the binary image mentioned above, the read 
multilevel image can have its format converted to the 

10 well-known JIFF using well-known JPEG compression and 
the image can be stored in a specific folder of the 
server device on the network via SLM 1515. 

If the destination device of distribution is a 
well-known e-mail server, then the mail address written 

15 in the address book 1502 is identified, the binary 
image, which has been read by the scanner, is 
compressed using well-known MMR compression, the format 
of the compressed image is converted to TIFF (Tagged 
Image File Format) and the image is transmitted to the 

20 e-mail server using the well-known SMTP (Simple Mail 
Transfer Protocol) 1514. Subsequent distribution is 
implemented in accordance with mail server 4550. 

<<Web Pull Print Application and Web Server 
Application>> 

25 The Web pull print application and the Web server 

application are not directly related to this embodiment 



and explanation of them are omitted here. 
<Operation> 

Next, operations of the image input/output 
apparatus 1001 having the aforesaid construction are 
5 explained. 

(Control Screen) 

First, displayed contents on the display screen 
of the operation unit 2102 will be briefly explained. 

The functions provided by the image input/output 

10 apparatus of the present invention are generally 

categorized into six, which are COPY, SEND, RETRIEVE, 
TASKS, MANAGEMENT and CONFIGURATION. These functions 
correspond to six main tabs, which are COPY 3011, SEND 
3012, RETRIEVE 3013, TASKS 3014, MGMT 3015, and CONFIG 

15 3016 displayed at the top of the control screen 2013 in 
Fig. 14. A changeover to the screen of each category 
is performed by pressing the corresponding main tab. 
When a changeover to the screen of a category is 
inhibited, the color of the main tab corresponding to 

20 the inhibited category is displayed in a different 
color, and nothing happens when this main tab is 
pressed. Fig. 14 shows a case where COPY is selected 
as an example. 

COPY includes a function for carrying out 

25 ordinary document copying using the scanner 2070 and 
printer 2095 included in the image input/output 
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apparatus 1001, and a function for copying documents 
using the scanner 2070 included in the apparatus 1001 
and a printer connected on the network {e.g., the 
printer 1040 in Fig. 1) . 
5 SEND is a function for transferring an image of a 

document, which has been placed in the scanner 2070 
included in the apparatus 1001, by electronic mail, to 
a remote printer, a facsimile machine and a database, 
and for submitting the document to file transfer (FTP) . 

10 A plurality of destinations can be specified. 

RETRIEVE is a function for acquiring a document 
image from the outside and printing the document image 
using the printer 2095 included in the apparatus 1001, 
The WWW, electronic mail, file transfer and facsimile 

15 can be used as means for acquiring an image. 

TASKS is for carrying output the generation and 
management of tasks for the purpose of automatically 
processing images sent from the outside, such as from a 
facsimile machine or Internet printer, and for 

20 retrieving images periodically. 

MANAGEMENT (MGMT) is for managing information 
such as jobs, address book, bookmarks, documents and 
accounts . 

CONFIGURATION (CONFIG) is for setting the 
25 apparatus 1001' (network configuration, clock, etc.). 
(Device Information Service (DIS) ) 



A database which retains, in a data format in 
compliance with the control API, set values regarding 
jobs in the controller, the functions and statuses of 
devices (scanners, printers, etc.) and billing 
5 information, and the interface with this database are 
defined as a Device Information Service (DIS) . Fig. 15 
illustrates the communication between a DIS 7102 and 
the job manager 1519, the scan manager 1524 and the- 
print manager 1526. 

10 Basically, dynamic information such as a job 

start instruction is issued from the job manager 1519 
directly to each manager, and static information such 
as device functions and job content is acquired by 
referring to the DIS 7102. Static and dynamic 

15 information and events from each manager are 

communicated to the job manager 1519 via the DIS 7102. 

In a case where the setting of data in the 
database of the DIS from each manager and the 
acquisition of data are performed, the fact that the 

20 internal data format of the DIS 7102 is in compliance 
with Control API means that processing is executed to 
perform a conversion between the data format in 
compliance with Control API and a data format that can 
be understood by each manager. For example, in a case 

25 where setting of status data is performed from each 
manager, device-specific information is interpreted, 



converted to corresponding data defined by Control API 
and then written to the database of the DIS 7102. 

In a case where the setting of data in the 
database of the DIS 7102 from the job manager and the 
acquisition of data are performed from the job manager 
1519, there is no conversion of data between the job 
manager 1519 and the DIS 7102. 

Further, updating of event data in the DIS 7102 
is performed based upon each item of event information 
reported by each manager. 

Fig. 16 illustrates various databases stored in 
the DIS 7102. These databases will now be described. 

A supervisor database 7201 stores status and user 
information regarding all devices. Information such as 
user IDs and passwords requiring back-up is stored on a 
hard disk or in a non-volatile storage device such as a 
back-up memory. 

A scan component database 7202 and a print 
component database 7203 store data in correspondence 
with each existing component. For example, in case of 
a device comprising solely a printer, only the print 
component database will be present. In case of a 
device equipped with a facsimile function, a fax 
component database is provided. When initializing each 
component database, the corresponding manager sets the 
component function and status in each component 
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database . 

A scan job service database 7204 and a print job 
service database 7205 are provided. In a manner 
similar to that of the component databases, the 
5 corresponding managers set the functions capable of 
being used by devices and their support conditions in 
these job service databases when initialization is 
carried out. 

Job databases and document databases will be 

10 described next. There are provided scan job databases 
7206, print job databases 7207, scan document databases 
7208 and print document databases 7209. 

A job database and a document database are 
acquired dynamically and initialized by the job manager 

15 1519 whenever a job and the document accompanying the 
job are generated. The setting of necessary items is 
also performed. Before the processing of a job starts, 
each manager reads the item necessary for processing 
out of the job database and document database and then 

20 starts the job. When a job subsequently ends, the 
databases of these jobs and their accompanying 
documents are released. Since a job may have more than 
one document, there are instances where a plurality of 
document databases are acquired for a certain job. 

25 A database 7210 stores event information 

communicated from each manager, and a counter table 



7211 is for recording the number of scans and the 
number of print operations of the apparatus. 

Events of which notification is given by the 
manager include status transition of a component, scan 
5 processing completion and various errors from the scan 
manager, as well as status transition of a component, 
print processing completion, paper jam and opening of a 
paper cassette from the print manager. Event IDs for 
identifying these events are determined in advance. 

10 If notification of an event is issued from a 

manager, the DIS 7102 registers the event ID issued to 
the event database 7210 and, if necessary, detailed 
data associated with the event. If cancellation of an 
event is communicated from a manager, the event data 

15 for which cancellation has been specified is deleted 
from the event database 7210. 

In a case where event polling from the job 
manager has taken place, the DIS 7102 refers to the 
event database 7210 and sends back the currently 

20 occurring event ID and, if necessary, detailed data 
that accompanies this event. If events are not 
currently occurring, this fact is sent back. 

If notification is given of a scan-processing 
complete event or print-processing complete event, the 

25 counter value of the client which has performed the 
scanning or printing operation is updated. In order 
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that the value of the count based upon this software 
will not be lost, as when power is inadvertently cut 
off, the count is written back, whenever the value is 
updated, to a non-volatile storage device such as a 
5 backed-up memory or hard disk. 
(Scanning Operation) 

Fig. 17 illustrates the software structure 
relating to scanning. The job manager 1519 has a 
function for classifying and storing application-level 

10 requests. The DIS 7102 stores the parameters necessary 
for a scanning operation from the application level. 
Requests from an application are stored in the RAM 2002. 
A scanning-operation management unit 8203 acquires 
information, which is necessary for scanning, from the 

15 job manager 1519 and DIS 7102. Note that the scan 

manager 1524 is configured with the scanning-operation 
management unit 8203, a scan-sequence control unit 8204 
and a device interface controller 8207. The scanning- 
operation management unit 8203 acquires table data 8301 

20 consisting of a job number and document number from the 
job manager 1519, and acquires scan parameters 8302, 
stored as shown in Fig. 18, from the DIS 7102 based 
upon the table data consisting of the job number 8305 
and document number 8302. The table shown in Fig. 18 

25 stores values when a scan job is occurred, and the job 
manager generates a unique document number. It should 



be noted that the job number 8305 in Fig. 18 is stored 
in the scan job database 7206 in Fig. 16, and the scan 
parameters 8302, such as the document number 8306, 
image file type 8307, scanned-image attribute 8308, and 
5 scanned-image compression format 8309 are stored in the 
scan document database 7208 in Fig. 16. As a result, 
scanning is performed based upon scan conditions 
requested from the application. 

The scanning-operation management unit 8203 

10 delivers the scan parameters acquired from the DIS 7102 
to the scan-sequence control unit 8204 in the order of 
the document numbers. After receiving the scan 
parameters 8302, the scan-sequence control unit 8204 
controls the device interface controller 8207 in 

15 accordance with the content of scanned-image attributes 
8308. As a result, by operating the device interface 
2020 connected to the image bus 2008 of Fig. 2, a 
control command is sent to the scanner 2070 via the 
cable 2071, whereby scanning is carried out. The 

20 scanned image is delivered to the device interface 2020 
via the cable 2071 and is stored in the RAM 2002 via 
the bus 2008. 

When scanning is completed and an image has been 
stored in the RAM 2002 via the bus 2008, the scan- 

25 sequence control unit 8204 sends a request to the CODEC 
manager 1520 in order to compress the scanned image 



that has been stored in the RAM 2002. Upon receiving 
the request, the CODEC manager 1520 uses the image 
compression/expansion unit 2040 connected to the bus 
2008 or the software compression module in the MMR 
5 CODEC 1523 to execute compressing in accordance with 
the designation of a scanned-image compression format 
8309 from the scan-sequence control unit 8204. The 
image compression/expansion unit 2040 stores the 
compressed image in the RAM 2002 via the bus 2008. 

10 When the CODEC manager 1520 compresses the 

scanned image to the format designated by the scanned- 
image compression format 8309 and stores the compressed 
image in the RAM 2002, the scan-sequence control unit 
8204 converts the compressed scanned image, which has 

15 been stored in the RAM 2002, to a file in accordance 
with an image file type 8307 of the scan parameters 
8302. The scan-sequence control unit 8204 requests a 
file system 8206 to convert the image to a file format 
designated by the image file type 8307 of the scan 

20 parameters 8302. In accordance with the image file 

type 8307 from the scan-sequence control unit 8204, the 
file system 8206 converts the compressed image stored 
in the RAM 2002 to a file and transfers the file to the 
hard-disk drive 2004 via the bus 2008, whereby the 

25 scanned compressed image is converted to a file. When 
the file system 8206 has stored the image in the form 
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of a file on the hard disk of the hard-disk drive 2004, 
the scan-sequence control unit 8204 sends back 
notification of completion of scanning to the scanning- 
operation management unit 8203. This indicates the 
5 completion of processing of one sheet of the document 
in the scanner 2070. 

If a document that has not yet been scanned is 
present in the scanner 2070 and there is a scan request 
from the job manager 1519, then the scan-sequence 

10 control unit 8204 is again requested to perform 

scanning by using the scan parameters 8302 stored in 
the DIS 7102. If an unscanned document is not present 
in the scanner 2070, or if there is no scan request 
from the job manager 1519, the job manager 1519 is 

15 notified of the completion of scanning. This indicates 
the end of the scanning operation. 
(Printing Operation) 

The details of the printing operation will now be 
described in detail. 

20 The device interface 2020 has an internal DPRAM 

and sets parameters in the printer 2095, reads out the 
state of the printer 2095 and exchanges printing 
control commands via the DPRAM. Further, this board 
has a video controller and transmits image data, which 

25 has been expanded on the bus 2008, to the printer 2095 
via an engine interface cable in sync with VCLK (a 



video clock) and HSYNC supplied from the printer 2095 
via the engine interface cable (cable for connecting 
the scanner 2070 and the controller 2000) . 
Transmission timing is shown in Fig. 19. VCLK is 
5 produced at all times and HSYNC is applied in sync with 
the start of one line of printing by the printer. The 
video controller (not shown) reads data in an amount 
equivalent to the set image width (WIDTH) out of the 
RAM 2002 and outputs the data to the engine interface 

10 cable as a video signal. After this is repeated for 
the designated number of lines (LINES) , the video 
controller generates an image-end interrupt. 

As described earlier, when a print-job command is 
delivered to the control API 1518 from an application 

15 program run by the CPU 2001, the control API delivers 
this command to the job manager 1519 of the control 
level as a job. Furthermore, the job manager 1519 
stores the job settings in the DIS 7102 and instructs 
the print manager 1526 to start the printing job. Upon 

20 accepting the job, the print manager 1526 reads 

information, which is necessary for job execution, out 
of the DIS 7102 and sets this information in the 
printer via the DPRAM. If an image has been compressed, 
the print manager 1526 requests the CODEC manager 1520 

25 to expand the image. In response to this request, the 
CODEC manager 1520 expands the image file into a bitmap 



image by an expansion method (JPEG, MMR, etc.) 
specified by the print manager 1526. The expanded 
image is stored in the RAM 2002. 

The setting items of the device interface 2020 
5 are shown in Fig. 20, and the setting items, control 
commands and status commands sent to the printer via 
the DPRAM are illustrated in Fig. 21. 

Operation with regard to printing of a bitmap - 
image will now be described in detail. It will be 
10 assumed that two pages (one copy each) of a binary 

image of letter size (11" x 8.5") are printed using a 
printer having a 600-dpi capability. 

When expansion of the image is finished, the 
print manager 1526 calculates the number of image bytes 
15 for an image of this width (8.5" in this case) as 
follows : 

WIDTH = 8.5 x 600 + 8 = 630 (bytes) 
The print manager 1526 then calculates the number of 
lines as follows: 

20 LINES = 11 x 600 = 6600 (lines) 

These calculated values and the source address of 
the RAM 2002 storing the image of the first page 
provided thereto are set at WIDTH, LINES and SOURCE 
shown in Fig. 20. Though preparation of the image 

25 output is completed at this point, the device interface 
does not output the image data because the HSYNC signal 
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from the printer 2095 has not yet arrived (though the 
VCLK signal is arriving) . 

Next, the print manager writes 1, which is the 
number of copies to be output, to a prescribed address 
5 (Book No.) of the DP RAM shown in Fig. 21. The print 
manager 1526 thenceforth issues a paper-feed request 
(FEED_REQ) for output of paper for the first page and 
waits for a request (IMAGE_REQ) for image data from- the 
printer 2095. When IMAGE_REQ arrives from the printer 
10 2095, the print manager 1526 issues IMAGE_START. Upon 
receiving IMAGERS TART , the printer 2095 starts issuing 
HSYNC and the interface 2020, which has been waiting 
for HSYNC, outputs the image. Upon detecting the 
trailing edge of the output paper, the printer 2095 
15 outputs a request (IMAGE_END) for termination of image 

data transmission. When the output paper is discharged, 
the printer outputs SHEET_OUT. The print manager 1526 
receives IMAGE_END of the first page, sets WIDTH, LINES, 
SOURCE of the second page in the engine interface board, 
20 outputs a paper-feed request (FEED_REQ) and waits for 
an image data request (IMAGE_REQ) . Operation following 
arrival of IMAGE_REQ of the second page is similar to 
that of the first page. 
[First Embodiment] 
25 Scanning operation that is performed when JPEG 

compression is executed by the scanner unit of an image 



input/output apparatus 1001 in the first embodiment of 
the present invention will be described below in detail. 

The hardware arrangement will be described first 
with reference to Fig. 22. Fig. 22 is a block diagram 
5 showing the detailed arrangement of a JPEG compression 
unit 2087 (Fig. 5) in an image processor 2080. As 
described above, a scanned multilevel image is input to 
the JPEG compression unit 2087. First, this image is 
converted by a color space converter 10002 from the 

10 standardized RGB color space to a luminance signal Y 
and color difference signals UV, which are generally 
called YUV. This conversion may be done from the RGB 
color space to the luminance signal Y and color 
difference signals CrCb, which are called YCrCb. 

15 A line-block converter 10003 stores image data 

input in units of lines in an SRAM 10004 and converts 
the image data of each line into 8 x 8 or 16 x 16 block 
data to be processed by JPEG. So-called 4:2:2 
sub-sampling for color difference signals can also be 

20 performed here. 

A discrete cosine transformer 10005 performs 
well-known discrete cosine transformation for the 
converted block image. 

A quantization unit 10006 quantizes the image 

25 data, which has undergone discrete cosine 

transformation, on the basis of a quantization table 



stored in this quantization unit. This quantization 
table is set such that low-frequency components are 
finely quantized while high-frequency components are 
coarsely quantized, as exemplified in Appendix K of 
5 Recommendation T.81 issued by the ITU-T. 

The quantized data is encoded by a Huffman codec 
10007 using Huffman encoding. 

The output Huffman code amount is counted by a 
code counter 10008. This counter is reset to 0 before 

10 the start of scanning and comprises a counter /register 
for obtaining the code amount after the image obtained 
by scanning is compressed. 

Operation of JPEG-compressing scanned image data 
in real time will be described next with reference to 

15 Fig. 23. 

In scanning, a scan-sequence control unit 8204 
notifies the apparatus of JPEG compression, so JPEG 
compression initial setting is done in step Sll. In 
this case, the image processing hardware constructing 

20 the above-described scanner image processor 2080 is set. 
In addition, the color space converter 10002 and the 
quantization table used by the quantization unit 10006 
shown in Fig. 22 are set, and the code counter 10008 is 
reset. The quantization table is set in accordance 

25 with a compression ratio instruction from the 

scan-sequence control unit 8204. As the quantization 



table, the table (to be referred to as "a standard 
quantization table" hereinafter) of ITU-T 
Recommendation T.81, Appendix K is basically used. A 
parameter QF representing a compression ratio is 
5 received from the scan-sequence control unit 8204. The 
value Q is calculated in accordance with this parameter 
QF and equations (1) and (2) below, and the standard 
quantization table is re-calculated and set. Examples 
of the equations will be shown below. The value Q 

10 takes an integer value ranging from 1 to 100. The 
value Q is obtained by the following equations, and 
each element of the quantization table is multiplied by 
Q/100. When the quantization step exceeds 255, it is 
clipped at 255. 

15 Q = 5000/QF (when QF < 

50) ...d) 

Q = 200 - QF x 2 (when QF > 
50) ...(2) 

The start address of the memory ensured by the 

20 scan-sequence control unit 8204, and the ensured memory 
capacity are set in an image bus interface controller 
2081. The image bus interface controller 2081 
decrements the ensured memory capacity, and when the 
capacity becomes 0, the transfer is stopped. For this 

25 reason, the image is not written beyond the ensured 
memory capacity. 



When setting of the image processing hardware is 
ended, the scan-sequence control unit 8204 is notified 
of completion of preparation in step S12. A codec 
manager 1520 notifies the scan-sequence control unit 
5 8204 of the completion of preparation after the image 
processing hardware is activated to transfer an image. 
However, at this time point, no image is transferred. 
Actually, a sync signal of image data is output from a 
scanner 2070 when the scan-sequence control unit 8204 

10 instructs the scanner 2070 to start scanning, and 
scanning starts. The sync signal triggers image 
transfer to the memory. The codec manager 1520 is 
notified of the end of image transfer through an 
interrupt signal from the image bus interface 

15 controller 2081 and an interrupt handler for that 

interrupt (step S13). If no interrupt is received, it 
is continuously waited. When an interrupt is received, 
it is determined whether the image data is completely 
stored in the memory area prepared by the scan-sequence 

20 control unit 8204 in advance. The codec manager 1520 
can know the size of the ensured memory area by a 
notification from the scan-sequence control unit 8204. 
The code amount of the actually compressed image can be 
obtained from the code counter 10008. In step S14, the 

25 two values are compared. If the actual compressed code 
data amount exceeds the size of the ensured memory area, 



the scan-sequence control unit 8204 is notified of the 
failure of scan data storage and the code data amount 
in step S15. Otherwise, the scan-sequence control unit 
8204 is notified of the success of scan data storage. 
5 The operation of the scan-sequence control unit 

8204 will be described next with reference to the flow 
chart shown in Fig. 24. 

In step S21, before scanning, the scanner 2070 is 
initialized. In this case, the memory area for holding 

10 image data after JPEG compression is ensured, and the 
codec manager 1520 is requested to set the image 
processing hardware for JPEG compression. The 
initially ensured memory area capacity is obtained by 
calculation using the compression ratio parameter QF 

15 and image size. For the compression ratio parameter QF, 
an instruction is issued by user setting, and a value 
complying with it is instructed. Fig. 25 is a table 
showing the user settings, parameters QF, and equations 
therefor . 

20 In step S22, processing waits for the end of 

image processing hardware setting by the codec manager 
1520. When setting is ended, the scanner 2070 is 
instructed to start scanning operation in step S23. In 
step S24, processing waits until a notification of the 

25 end of image transfer is received from the codec 

manager 1520. When a notification is received, and the 
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image data is completely stored in the memory area 
prepared by the scan-sequence control unit 8204 (NO in 
step S25) , the flow advances to step S26 to notify a 
scanning-operation management unit 8203 of the result, 
5 and the processing is ended. If the image data is not 
completely stored (YES in step S25), the flow advances 
to step S27 to determine whether it is the first 
scanning for a single original. If the scanning is -in 
the second or subsequent cycle, the scanning-operation 

10 management unit 8203 is notified of the failure of scan 
image reception in step S26. This information is 
displayed on the control unit 2012 through the job 
manager 1520 or an application requested for the job, 
and the user is notified of it. 

15 If scanning is in the first cycle (YES in step 

527) , settings are changed, and scanning is tried again 
More specifically, first, the necessary memory size the 
codec manager 1520 notified is referred to. If an 
extra memory area of about 5% can be ensured in 

20 addition to the necessary memory size (YES in step S28) 
the memory area is ensured, and the flow returns to 
step S21 to perform initial setting again. If the 
necessary memory area cannot be ensured (NO in step 

528) , the maximum memory area available is ensured in 
25 step S29, and the compression ratio setting is dropped 

by one step, and initial setting is done in step S21. 
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As described above, in the first embodiment of 
the present invention, in re-scanning as performing 
JPEG compression, the necessary memory capacity is 
measured in the first scanning. On the basis of the 
5 measured capacity, if the necessary memory area cannot 
be acquired, the maximum memory area available is 
ensured, and scanning is performed while the 
compression ratio setting is automatically dropped by 
one step. Hence, the image JPEG-compressed in the 

10 second scanning can be stored in the memory, and user's 
operability of the apparatus can be improved. 
[Second Embodiment] 

The second embodiment will be described. 
Scanning operation that is performed when JPEG 

15 compression is executed by the scanner unit of an image 
input/output apparatus 1001 in the second embodiment of 
the present invention will be described below in detail. 
The operation of the codec manager 1520 is the same as 
that described in the first embodiment with reference 

20 to Fig. 23, and a detailed description thereof will be 
omitted. 

The operation of a scan-seguence control unit 
8204 in the second embodiment will be described with 
reference to the flow chart shown in Fig. 26. 
25 In step S31, before scanning, the scanner 2070 is 

initialized. In this case, the memory area for holding 



image data after JPEG compression is ensured, and the 
codec manager 1520 is requested to set the image 
processing hardware for JPEG compression. The 
initially ensured memory area capacity is obtained from 
5 the image size. Sine a compression ratio of about 1/10 
the image size can easily be obtained by JPEG, a memory 
capacity corresponding to (image size x 1/10) is 
acquired. 

In step S32, processing waits for the end of 

10 image processing hardware setting by the codec manager 
1520. When setting is ended, the scanner 2070 is 
instructed to start scanning operation in step S33. As 
the resolution, that instructed by a control unit 2012 
is used if it is the first scanning. In step S34, 

15 processing waits until a notification of the end of 

image transfer is received from the codec manager 1520. 
When a notification is received, and the image data is 
completely stored in the memory area prepared by the 
scan-sequence control unit 8204 (NO in step S35) , the 

20 flow advances to step S36 to notify the 

scanning-operation management unit 8203 of the result, 
and the processing is ended. If the image data is not 
completely stored (YES in step S35) , the flow advances 
to step S37 to determine whether it is the first 

25 scanning for a single original. If the scanning is in 
the second or subsequent cycle, the scanning-operation 
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management unit 8203 is notified of the failure of scan 
image reception in step S36. This information is 
displayed on the control unit 2012 through the job 
manager 1520 or an application reguested for the job, 
5 and the user is notified of it. 

If scanning is in the first cycle (YES in step 
S37), settings are changed, and scanning is tried again 
More specifically, first, the necessary memory size- the 
codec manager 1520 notified is referred to. If an 

10 extra memory area of about 5% can be ensured in 

addition to the necessary memory size (YES in step S38) 
the memory area is ensured, and the flow returns to 
step S31 to perform initial setting again. If the 
necessary memory area cannot be ensured (NO in step 

15 S38), the maximum memory area available is ensured in 
step S39, and the scanning resolution setting is 
dropped by 100 dpi. For example, when the setting by 
the control unit is 400 dpi, initial setting is 
performed in step S31 such that the resolution is 

20 dropped to 300 dpi for scanning. The manner the 
resolution is dropped may be set by the user 
himself /herself using the user mode window shown in 
Fig. 27. In accordance with the user mode setting, the 
scan-sequence control unit sets the resolution again 

25 and rescans. For input, the decrease amount of the 

resolution is input to a box 11002 using a ten-key pad 
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11001. 

In the second embodiment, the method of changing 
the scanning resolution itself has been described. 
However, even when the sampling rate for the color 
5 difference signals is changed to 4 : 4 : 4 , 4 : 2 : 2 , 
or 4 : 1 : 1 by a line-block converter 10003, the same 
effect as described above can be obtained. 

As described above, in the second embodiment, - in 
re-scanning for JPEG compression that is executed 

10 simultaneously with scanning in real time, the 

necessary memory capacity is measured by the first 
scanning. On the basis of the measured capacity, if 
the necessary memory area cannot be acquired, the 
maximum memory area available is ensured, and scanning 

15 is performed while the scanning ratio is automatically 
dropped. Hence, the image JPEG-compressed in the 
second scanning can be stored in the memory, and user's 
operability of the apparatus can be improved. 
[Third Embodiment] 

20 The third embodiment will be described. 

Scanning operation that is performed when JPEG 
compression is executed by the scanner unit of an image 
input/output apparatus 1001 in the third embodiment of 
the present invention will be described below in detail. 

25 The operation of the codec manager 1520 is the same as 
that described in the first embodiment with reference 
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to Fig. 23, and a detailed description thereof will be 
omitted. 

The operation of a scan-sequence control unit 
8204 in the third embodiment will be described with 
5 reference to the flow chart shown in Fig. 28. 

In step S41, before scanning, the scanner 2070 is 
initialized. In this case, the memory area for holding 
image data after JPEG compression is ensured, and the 
codec manager 1520 is requested to set the image 

10 processing hardware for JPEG compression. In addition, 
the maximum number of times of re-scanning (maximum 
number of times of scanning operations) when the 
compressed image cannot be completely stored in the 
ensured memory area is instructed by the control unit 

15 2012. The initially ensured memory area capacity is 
obtained by calculation using a compression ratio 
parameter QF and image size. For the compression ratio 
parameter QF, an instruction is issued by user setting, 
and a value complying with it is instructed. Fig. 25 

20 is a table showing the user settings, parameters QF, 
and equations therefor. 

In step S42, processing waits for the end of 
image processing hardware setting by the codec manager 
1520. When setting is ended, the scanner 2070 is 

25 instructed to start scanning operation in step S43. In 
step S44, processing waits until a notification of the 



end of image transfer is received from the codec 
manager 1520. When a notification is received, and the 
image data is completely stored in the memory area 
prepared by the scan-sequence control unit 8204 (NO in 
5 step S45) , the flow advances to step S46 to notify a 
scanning-operation management unit 8203 of the result, 
and the processing is ended. If the image data is not 
completely stored (YES in step S45) , the flow advances 
to step S47 to determine whether it is scanning 

10 operation within the designated scanning cycles for a 
single original. If the scanning is in a subsequent 
cycle of the designated scanning cycles, the 
scanning-operation management unit 8203 is notified of 
the failure of scan image reception in step S46. This 

15 information is displayed on the control unit 2012 
through the job manager 1520 or an application 
requested for the job, and the user is notified of it. 

Fig. 29 is a view showing the setting window. 
The number of times of scanning is set in a setup box 

20 11003 using a ten-key pad 11001. Scanning operation is 
allowed to be repeated within the set number of times. 

If the number of times of scanning is less than 
the designated number of times (YES in step S47), 
settings are changed, and scanning is tried again. 

25 More specifically, first, the necessary memory size the 
codec manager 1520 notified is referred to. If an 



extra memory area of about 5% can be ensured in 
addition to the necessary memory size (YES in step S48), 
the memory area is ensured, and the flow returns to 
step S41 to perform initial setting again. If the 
5 necessary memory area cannot be ensured (NO in step 
S48), the maximum memory area available is ensured in 
step S49, and the compression ratio setting is dropped 
by one step, and initial setting is done in step S41. 
"One step" means a step settable by the user through 
10 the control unit 2012, or the compression ratio 

parameter QF held by the scan-sequence control unit 
8204. 

In the third embodiment, when the compressed scan 
image is stored in the ensured memory area, the 
15 . processing is ended even when the number of times of 
scanning performed is less than the designated number 
of times. 

As described above, in the third embodiment of 
the present invention, since the user can set an 
20 arbitrary number of times as a maximum scan count 

through the control unit, in addition to the effect 
obtained in the first embodiment, an image 
JPEG-compressed by a plurality of number of times of 
scanning can be stored in the memory, and user's 
25 operability of 'the apparatus can be improved. 

In the first to third embodiments, JPEG 
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compression has been described. However, the present 
invention is not limited to this. The same effect as 
described above can be obtained when the present 
invention is used to compress image data in real time 
5 by variable-length encoding. 
<Other Embodiment> 

The present invention can be applied to a system 
constituted by a plurality of devices (e.g., host 
computer, interface, reader, printer) or to an 

10 apparatus comprising a single device (e.g., copying 
machine, facsimile machine) . 

Further, the object of the present invention can 
also be achieved by providing a storage medium storing 
program codes for performing the aforesaid processes to 

15 a computer system or apparatus (e.g., a personal 

computer) , reading the program codes, by a CPU or MPU 
of the computer system or apparatus, from the storage 
medium, then executing the program. 

In this case, the program codes read from the 

20 storage medium realize the functions according to the 

embodiments, and the storage medium storing the program 
codes constitutes the invention. 

Further, the storage medium, such as a floppy 
disk, a hard disk, an optical disk, a magneto-optical 

25 disk, CD-ROM, CD-R, a magnetic tape, a non-volatile 

type memory card, and ROM can be used for providing the 



program codes. 

Furthermore, besides aforesaid functions 
according to the above embodiments are realized by 
executing the program codes which are read by a 
5 computer, the present invention includes a case where 
an OS (operating system) or the like working on the 
computer performs a part or entire processes in 
accordance with designations of the program codes and 
realizes functions according to the above embodiments. 

10 Furthermore, the present invention also includes 

a case where, after the program codes read from the 
storage medium are written in a function expansion card 
which is inserted into the computer or in a memory 
provided in a function expansion unit which is 

15 connected to the computer, CPU or the like contained in 
the function expansion card or unit performs a part or 
entire process in accordance with designations of the 
program codes and realizes functions of the above 
embodiments . 

20 In a case where the present invention is applied 

to the aforesaid storage medium, the storage medium 
stores program codes corresponding to the flowcharts in 
Figs. 23 and 24, 26 or 28 described in the embodiments. 
As many apparently widely different embodiments of 

25 the present invention can be made without departing from 
the spirit and scope thereof, it is to be understood 



that the invention is not limited to the specific 
embodiments thereof except as defined in the appended 
claims . 



WHAT IS CLAIMED IS: 

1. A control method for an image input apparatus for 
reading an original and compressing image data of the 
read original in real time, said method comprising: 

5 a memory area ensuring step of ensuring a memory 

area for storing compressed image data; 

a read step of reading an original and outputting 
image data; 

a compression step of compressing the image data 
10 in real time; 

a storage step of storing the compressed image 
data in the memory area ensured in said memory area 
ensuring step; 

a determination step of determining whether the 
15 compressed image data is completely stored in the 
memory area; 

a compression ratio change step of, when it is 
determined in said determination step that the image 
data is not completely stored, changing a compression 
20 ratio in the compression step; and 

a repeat step of, when the compression ratio is 
changed in said compression ratio change step, 
controlling to repeat said read step, said compression 
step, and said storage step using the changed 
25 compression ratio. 

2. The method according to claim 1 further 
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comprising : 

a measurement step of measuring a data amount of 
the compressed image data; and 

a memory area re-ensuring step of, when it is 
5 determined in said determination step that the image 
data is not completely stored, re-ensuring a memory 
area capable of storing image data in the data amount 
measured in said measurement step or a maximum memory 
area available when the memory area cannot be ensured, 

10 wherein, in said compression ratio change step, 

the compression ratio for the compression step is 
changed if it is determined in said determination step 
that the image data is not completely stored and if the 
memory area capable of storing the image data having 

15 the data amount measured in said measurement step 

cannot be ensured in said memory area re-ensuring step, 
and 

said repeat step controls to repeat said read 
step, said compression step, and said storage step 
20 after said memory area re-ensuring step and said 

compression ratio change step if it is determined in 
said determination step that the image data is not 
completely stored. 

3. The method according to claim 1 further 
25 comprising an input step of inputting the maximum 

number of times of read of a single original in said 
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read step, 

wherein, if the number of times of said read step 
repeated is smaller than the maximum number of times, 
said determination step to said repeat step is 
5 performed. 

4. The method according to claim 1, wherein, in said 
memory area ensuring step, the memory is ensured on the 
basis of the compression ratio and an original size. 

5. The method according to claim 1, wherein, in said 
10 compression ratio change step, the compression ratio is 

increased by one step. 

6. The method according to claim 1, wherein, in said 
compression step, JPEG compression is performed. 

7 . A control method for an image input apparatus for 
15 reading an original and compressing image data of the 

read original in real time, said method comprising: 

a memory area ensuring step of ensuring a memory 
area for storing compressed image data; 

a read step of reading an original and outputting 
2 0 image data; 

a compression step of compressing the image data 
in real time; 

a storage step of storing the compressed image 
data in the memory area ensured in said memory area 
25 ensuring step; ' 

a determination step of determining whether the 
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compressed image data is completely stored in the 
memory area; 

a resolution change step of, when it is 
determined in said determination step that the image 
5 data is not completely stored, changing a resolution in 
said read step; and 

a repeat step of, when the resolution is changed 
in said resolution change step, controlling to repeat 
said read step, said compression step, and said storage 
10 step using the changed resolution. 

8 . The method according to claim 7 further 
comprising : 

a measurement step of measuring a data amount of 
the compressed image data; and 

15 a memory area re-ensuring step of, when it is 

determined in said determination step that the image 
data is not completely stored, re-ensuring a memory 
area capable of storing image data in the data amount 
measured in the measurement step or a maximum memory 

20 area available when the memory area cannot be ensured, 
wherein, in said resolution change step, the 
resolution for said read step is changed if it is 
determined in said determination step that the image 
data is not completely stored and if the memory area 

25 capable of storing the image data having the data 
amount measured in said measurement step cannot be 
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ensured in said memory area re-ensuring step, and 

said repeat step controls to repeat said read 
step, said compression step, and said storage step 
after said memory area re-ensuring step and said 
5 resolution change step if it is determined in said 
determination step that the image data is not 
completely stored. 

9. The method according to claim 7 further 
comprising an input step of inputting the maximum 

10 number of times of read of a single original in the 
read step, 

wherein, if the number of times of said read step 
repeated is smaller than the maximum number of times, 
said determination step to said repeat step is 
15 performed. 

10. The method according to claim 7, wherein, in said 
memory area ensuring step, the memory area is ensured 
on the basis of an original size. 

11. The method according to claim 7, wherein, in said 
20 resolution change step, the resolution is decreased by 

one step. 

12. The method according to claim 11 further 
comprising a setting step of setting a width of 
one-step decrease of the resolution. 

25 13. The method according to claim 7, wherein, in said 
resolution change step, the resolution is changed for a 



color difference component of the image data. 

14. The method according to claim 7, wherein, in said 
compression step, JPEG compression is performed. 

15. An image input apparatus comprising: 

5 memory area ensuring means for ensuring a memory 

area for storing compressed image data; 

read means for reading an original and outputting 
image data; 

compression means for compressing the image data 
10 in real time; 

storage means for storing the compressed image 
data in the memory area ensured by said memory area 
ensuring means; 

determination means for determining whether the 
15 compressed image data is completely stored in the 
memory area; 

compression ratio change means for, when it is 
determined by said determination means that the image 
data is not completely stored, changing a compression 
20 ratio used by said compression means; and 

control means for, when the compression ratio is 
changed by said compression ratio change means, 
controlling to repeat the read of the original using 
the changed compression ratio. 
25 16. The apparatus according to claim 15 further 
comprising : 
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measurement means for measuring a data amount of 
the compressed image data; and 

memory area re-ensuring means for, when it is 
determined by said determination means that the image 
5 data is not completely stored, re-ensuring a memory 
area capable of storing image data in the data amount 
measured by said measurement means or a maximum memory 
area available when the memory area cannot be ensured, 
wherein said compression ratio change means 

10 changes the compression ratio to be used by said 
compression means if it is determined by said 
determination means that the image data is not 
completely stored and if the memory area capable of 
storing the image data having the data amount measured 

15 by said measurement means cannot be ensured by said 
memory area re-ensuring means, and 

said control means controls to repeat the read of 
the original after the memory area is re-ensured by 
said memory area re-ensuring means and/or after the 

20 compression ratio is changed by said compression ratio 
change means if it is determined by said determination 
means that the image data is not completely stored. 
17. The apparatus according to claim 15 further 
comprising input means for inputting the maximum number 

25 of times of read of a single original by said read 
means, 



wherein, if the number of times of read operation 
of the single original by said read means is smaller 
than the maximum number of times and if it is 
determined by said determination means that the image 
5 data is not completely stored, said control means 

controls to repeat the read by said read means after 
the memory area is re-ensuring by said memory area 
re-ensuring means and/or after the compression ratio is 
changed by said compression ratio change means. 
10 18. The apparatus according to claim 15, wherein said 
memory area ensuring means ensures the memory are on 
the basis of the compression ratio and an original size. 

19. The apparatus according to claim 15, wherein said 
compression ratio change means increases the 

15 compression ratio by one step. 

20. The apparatus according to claim 15, wherein said 
compression means performs JPEG compression. 

21. An image input apparatus comprising: 

memory area ensuring means for ensuring a memory 
20 area for storing compressed image data; 

read means for reading an original and outputting 
image data; 

compression means for compressing the image data 
in real time; 

25 storage means for storing the compressed image 

data in the memory area ensured by said memory area 



ensuring means; 

determination means for determining whether the 
compressed image data is completely stored in the 
memory area; 

5 resolution change means for, when it is 

determined by said determination means that the image 
data is not completely stored, changing a resolution 
used by said read means; and 

control means for, when the resolution is 
10 changed by said resolution change means, controlling to 
repeat the read of the original using the changed 
resolution . 

22. The apparatus according to claim 21 further 
comprising 

15 measurement means for measuring a data amount of 

the compressed image data; and 

memory area re-ensuring means for, when it is 

determined by said determination means that the image 

data is not completely stored, re-ensuring a memory 
20 area capable of storing image data in the data amount 

measured by said measurement means or a maximum memory 

area available when the memory area cannot be ensured, 
wherein said resolution change means changes the 

resolution to be used by said read means if it is 
25 determined by said determination means that the image 

data is not completely stored and if the memory area 



capable of storing the image data having the data 
amount measured by said measurement means cannot be 
ensured by said memory area re-ensuring means, and 

said control means controls to repeat the read of 
5 the original after the memory area is re-ensured by 
said memory area re-ensuring means and/or after the 
resolution is changed by said resolution change means 
if it is determined by said determination means that 
the image data is not completely stored. 
10 23. The apparatus according to claim 21 further 

comprising input means for inputting the maximum number 
of times of read of a single original by said read 
means , 

wherein, if the number of times of read operation 
15 of the single original by said read means is smaller 
than the maximum number of times and if it is 
determined by said determination means that the image 
data is not completely stored, said control means 
controls to repeat the read by said read means after 
20 the memory area is re-ensured by said memory area 
re-ensuring means and/or after the resolution is 
changed by said resolution change means. 

24. The apparatus according to claim 21, wherein said 
memory area ensuring means ensures the memory area on 

25 the basis of an original size. 

25. The apparatus according to claim 21, wherein said 
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resolution change means decreases the resolution by one 
step. 

26. The apparatus according to claim 25 further 
comprising setting means for setting a width of 

5 one-step decrease of the resolution. 

27. The apparatus according to claim 21, wherein said 
resolution change means changes the resolution for a 
color difference component of the image data. 

28. The apparatus according to claim 21, wherein said 
10 compression means performs JPEG compression. 

29. A computer program product comprising a computer 
usable medium having computer readable program code 
means embodied in said medium for a control method for 
an image input apparatus for reading an original and 

15 compressing image data of the read original in real 
time, said product including: 

first computer readable program code means of 
ensuring a memory area for storing compressed image 
data; 

20 second computer readable program code means of 

reading an original and outputting image data; 

third computer readable program code means of 
compressing the image data in real time; 

fourth computer readable program code means of 
25 storing the compressed image data in the memory area 
ensured by said first computer readable program code 



means ; 

fifth computer readable program code means of 
determining whether the compressed image data is 
completely stored in the memory area; 
5 sixth computer readable program code means of, 

when it is determined by said fifth computer readable 
program code means that the image data is not 
completely stored, changing a compression ratio used by 
said third computer readable program code means; and 

10 seventh computer readable program code means of, 

when the compression ratio is changed by said sixth 
computer readable program code means, controlling to 
execute said second to fourth computer readable program 
code means using the changed compression ratio. 

15 30. A computer program product comprising a computer 
usable medium having computer readable program code 
means embodied in said medium for a control method for 
an image input apparatus for reading an original and 
compressing image data of the read original in real 

20 time, said product including: 

first computer readable program code means of 
ensuring a memory area for storing compressed image 
data; 

second computer readable program code means of 
25 reading an original and outputting image data; 

third computer readable program code means of 



compressing the image data in real time; 

fourth computer readable program code means of 
storing the compressed image data in the memory area 
ensured by said first computer readable program code 
5 means; 

fifth computer readable program code means of 
determining whether the compressed image data is 
completely stored in the memory area; 

sixth computer readable program code means of, 
10 when it is determined by said fifth computer readable 
program code means that the image data is not 
completely stored, changing a resolution used by said 
second computer readable program code means; and 

seventh computer readable program code means of, 
15 when the resolution is changed by said sixth computer 
readable program code means, controlling to execute 
said second to fourth computer readable program code 
means using the changed resolution. 



ABSTRACT OF THE DISCLOSURE 
In an image input apparatus for compressing, in 
real time, image data obtained by reading an image and 
storing it in a memory, a memory area is ensured, an 
original is read and its image data is outputted, the 
image data is compressed in real time, the compressed 
image data is stored in the memory area, and it is 
determined whether the compressed image data is 
completely stored in the memory area. If it is 
determined that the image data is not completely stored, 
the compression ratio is increased, and the original 
read, compression of read image data, and storage of 
the compressed image data are repeated using the 
changed compression ratio. 
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COMBINED DECLARATION AND POWER OF ATTORNEY FOR 
ORIGINAL , DESIGN, NATIONAL STAGE OF PCT, SUPPLEMENTAL, 
DIVISIONAL. CONTINUATION OR CONTINUATION-IN-PART APPLICATION 

As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my name, 

I believe I am the original, first and sole inventor (if only one name is listed below) or an original, first and joint 
inventor (if plural names are listed below) of the subject matter which is claimed and for which a patent is sought on the 
invention entitled: 

IMAGE INPUT APPARATUS AND CONTROL METHOD THEREFOR 

the specification of which 

a. [ x ] is attached hereto 

b. [ ] was filed on as application Serial No. and 

was amended on (if applicable). 

PCT FILED APPLICATION ENTERING NATIONAL STAGE 

C. [ ] was described and claimed in International Application No. filed on 

and as amended on .(if any). 

I hereby state that I have reviewed and understand the contents of the above-identified specification, including the claims, 
as amended by any amendment referred to above. 

I acknowledge the duty to disclose information which is material to the examination of this application in accordance 
with Title 37, Code of Federal Regulations, § 1.56(a). 

I hereby specify the following as the correspondence address to which all communications about this application are to 
be directed: 

SEND CORRESPONDENCE TO: MORGAN & FINNEGAN, L.L.P. 

345 Park Avenue 
New York, N.Y. 10154 

DIRECT TELEPHONE CALLS TO: MICHAEL M. MURRAY 

(212) 758-4800 

[X] I hereby claim foreign priority benefits under Title 35, United States Code § 1 19 (a)-(d) or under § 365(b) 
of any foreign application(s) for patent or inventor's certificate or under § 365(a) of any PCT international application(s) 
designating at least one country other than the U.S. listed below and also have identified below such foreign 
application(s) for patent or inventor's certificate or such PCT international application(s) filed by me on the same 
subject matter having a filing date within twelve (12) months before that of the application on which priority is 
claimed: 

[X] The attached 35 U.S.C. § 1 19 claim for priority for the application s) listed below forms a part of this 
declaration. 
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Application Date of filing Date of issue Priority 

Country/PCT Number (dav.month.vr) (dav.month.vr) Claimed 

Japan 11-314138 04, 11, 1999 r x 1YES r TNO 

r iyes r iNQ 

[ ] I hereby claim the benefit under 35 U.S.C. § 1 19(e) of any U.S. provisional application(s) listed below. 
Provisional Application No. Date of filing (day, month, yr") 



ADDITIONAL STATEMENTS FOR DIVISIONAL, CONTINUATION OR CONTINUATION-IN-PART 
OR PCT INTERNATIONAL APPLICATIONS DESIGNATING THE U.S.) 

I hereby claim the benefit under Title 35, United States Code § 120 of any United States application(s) or under § 365(c) 
of any PCT international application(s) designating the U.S. listed below. 



US/PCT Application Serial No. Filing Date, Status (patented, pending, abandoned)/ 

U.S. application no. assigned (For PCT) 



US/PCT Application Serial No. Filing Date, Status (patented, pending, abandoned)/ 

U.S. application no. assigned (For PCT) 

[ ] In this continuation-in-part application, insofar as the subject matter of any of the claims of this application 
is not disclosed in the above listed prior United States or PCT international application(s) in the manner provided by the 
first paragraph of Title 35, United States Code, § 1 12, I acknowledge the duty to disclose material information as 
defined in Title 37, Code of Federal Regulations, § 1.56(a) which occurred between the filing date of the prior 
application(s) and the national or PCT international filing date of this application. 

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on 
information and belief are believed to be true; and further that these statements were made with the knowledge that 
willful false statements and the like so made are punishable by fine or Imprisonment, or both, under Section 1001 of 
Title 1 8 of the United States Code and that such willful false statements may jeopardize the validity of the application 
or any patent issued thereon. 

I hereby appoint the following attorneys and/or agents with full power of substitution and revocation, to prosecute this 
application, to receive the patent, and to transact all business in the Patent and Trademark Office connected therewith: 
John A. Diaz (Reg. No. 19,550), John C. Vassil (Reg. No. 19,098), Alfred P. Ewert (Reg. No. 19,887), David H. 
Pfeffer, P.C. (Reg. No. 19,825), Harry C. Marcus (Reg. No. 22,390), Robert E. Paulson (Reg. No. 21,046), Stephen 
R. Smith (Reg. No. 22,615), Kurt E. Richter (Reg. No. 24,052), J. Robert Dailey (Reg. No. 27,434), Eugene Moroz 
(Reg. No. 25,237), John F. Sweeney (Reg. No. 27,471), Arnold I. Rady (Reg. No. 26,601), Christopher A. Hughes 
(Reg. No. 26,914), William S. Feiler (Reg. No. 26,728), Joseph A. Calvaruso (Reg. No. 28,287), James W. Gould 
(Reg. No. 28,859), Richard C. Komson (Reg. No. 27,913), Israel Blum (Reg. No. 26,710), Bartholomew Verdirame 
(Reg. No. 28,483), Maria C. H. Lin (Reg. No. 29,323), Joseph A. DeGirolamo (Reg. No. 28,595), Michael A. 
Nicodema (Ref. No. 33,199), Michael P. Dougherty (Ref. No. 32,730), Seth J. Altas (Reg. No. 32,454), Andrew M. 
Riddles (Reg. No. 31,657), Bruce D. DeRenzi (Reg. No. 33,676), Michael M. Murray (Reg. No. 32,537) and Mark J. 
Abate (Reg. No. 32,527); Alfred L. Haffner, Jr. (Reg. No. 18,919), Harold Haidt (Reg. No. 17,509), John T. Gallagher 
(Reg. No. 35,516), Steven F. Meyer (Reg. No. 35,613); Kenneth H. Sonnenfeld (Reg No. 33,285), Edward A. 
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Pennington (Reg. No. 32,588), Michael S. Marcus (Reg. No. 31,727) and John E. Hoel (Reg. No. 26,279) of Morgan 
& Finnegan, L.L.P., whose address is: 345 Park Avenue, New York, New York 10154. 



[ ] I hereby authorize the U.S. attorneys and/or agents named hereinabove to accept and follow 

instructions from 

as to any 

action to be taken in the U.S. Patent and Trademark Office regarding this application without direct 
communication between the U.S. attorneys and/or agents and me. In the event of a change in the person(s) 
from whom instructions may be taken I will so notify the U.S. attorneys and /or agents named hereinabove. 



Full name of sole or first inventor Hiroyuki YAGUCHI 

Inventor's signature* J<fiyZ£?zfrA$Jll > 



date (^^e^_7^^^ 
Residence Kanaqawa , Japan 



Citizenship JAPAN 



c/o CANON KABUSHIKI KAISHA, 
Post Office Address 30-2, Shimomaruko 3-chome, Ohta-ku, Tokyo, Japan 



Full name of second joint inventor, if any _ 
Inventor's signature* 



Residence 



Citizenship 

Post Office Address __ 

[ ] ATTACHED IS ADDED PAGE TO COMBINED DECLARATION AND POWER OF ATTORNEY 
FOR SIGNATURE BY THIRD AND SUBSEQUENT INVENTORS FORM. 

* Before signing this declaration, each person signing must: 

1 . Review the declaration and verify the correctness of all information therein; and 

2. Review the specification and the claims, including any amendments made to the claims. 
After the declaration is signed, the specification and claims are not to be altered. 



To the inventor(s): 

The following are cited in or pertinent to the declaration attached to the accompanying application: 

Title 37. Code of Federal Regulation. § 1.56 

Duty to disclose information material to patentability. 

(a) A patent by its very nature is affect with a public interest. The public interest is best served, 
and the most effective patent examination occurs when, at the time an application is being examined, 
the Office is aware of and evaluates the teachings of all information material to patentability. Each 
individual associated with the filing and prosecution of a patent application has a duty of candor and 
good faith in dealing with the Office, which includes a duty to disclose to the Office all information 
known to that individual to be material to patentability as defined in this section. The duty to disclose 
information exists with respect to each pending claim until die claim is canceled or withdrawn from 
consideration, or the application becomes abandoned. Information material to the patentability of a 
claim that is.canceled or withdrawn from consideration need not be submitted if the information is not 
material to the patentability of any claim remaining under consideration in the application. There is no 
duty to submit information which is not material to the patentability of any existing claim. The duty to 
disclose all information known to be material to patentability is deemed to be satisfied if all 
information known to be material to patentability of any claim issued in patent was cited by the Office 
or submitted to the Office in the manner prescribed by §§ 1 .97(b)-(d) and 1.98. However, no patent will 
be granted on an application in connection with which fraud on the Office was practiced or attempted 
or the duty of disclosure was violated through bad faith or intentional misconduct. The Office 
encourages applicants to carefully examine: 

(1) prior art cited in search reports of a foreign patent office in a counterpart application, 

and 

(2) the closest information over which individuals associated with the filing or 
prosecution of a patent application believe any pending claim patentably defines, to 
make sure that any material information contained therein is disclosed to the Office. 

Title 35. U.S. Code S 101 
Inventions patentable 

Whoever invents or discovers any new and useful process, machine, manufacture, or composition of 
matter, or any new and useful improvement thereof, may obtain a patent therefor, subject to the conditions and 
requirements of this title. 



Title 35 U.S. Code 6 107 

Conditions for patentability; novelty and loss of right to patent 
A person shall be entitled to a patent unless - 

(a) the invention was known or used by others in this country, or patented or described in a 
printed publication in this or a foreign country, before the invention thereof by the applicant for patent, 

(b) the invention was patented or described in a printed publication in this or foreign country or in 
public use or on sale in this country, more than one year prior to the date of application for patent in the United 
States, or 
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(c) he has abandoned the invention, or 

(d) the invention was first patented or caused to be patented, or was the subject of an inventor's 
certificate, by the applicant or his legal representatives or assigns in a foreign country prior to the date of the 
application for patent in this country on an application for patent or inventor's certificate field more than twelve 
months before the filing of the application in the United States, or 

(e) the invention was described in a patent granted on an application for patent by another filed in 
the United States before the invention thereof by the applicant for patent, or on an international application by 
another who has fulfilled the requirements of paragraphs (1), (2), and (4) of section 371(c) of this title before 
the invention thereof by the applicant for patent, or 

(f) he did not himself invent the subject matter sought to be patented, or 

(g) before the applicant's invention thereof the invention was made in this country by another had 
not abandoned, suppressed, or concealed it In determining priority of invention there shall be considered not 
only the respective dates of conception and reduction to practice of the invention, but also the reasonable 
diligence of one who was first to conceive and last to reduce to practice, from a time prior to conception bv the 
other... 



Title 35. U.S. CodeS 103 



Conditions for patentability; non-obvious subject matter 



A patent may not be obtained though the invention is not identically disclosed or described as set forth 
in section 102 of this title, if the differences between the subject matter sought to be patented and the prior art 
are such that the subject matter as a whole would have been obvious at the time the invention was made to a 
person having ordinary skill in the art to which said matter pertains. Patentability shall not be negatived by the 
manner in which the invention was made. 



Subject matter developed by another person, which qualifies as prior art only under subsection (f) or 
(g) of section 102 of this title, shall not preclude patentability under this section where the subject matter and the 
claimed invention were, at the time the invention was made, owned by the same person or subject to an 
obligation of assignment to the same person. 



Title 35. U.S. Code S 117 fin p ar rt 
Specification 



The specification shall contain a written description of the invention, and of the manner and process of 
making and using it, in such full, clear, concise and exact terms also enable any person skilled in the art to 
which it pertains, or with which it is mostly nearly connected, to make and use the same, and shall set forth the 
best mode contemplated by the inventor of carrying out his invention. 



Title 35. U S, Code 8119 

Benefit of earlier filing date in foreign country; right of priority 

An application for patent for an invention filed in this country by any person who has or whose legal 
representatives or assigns have, previously regularly filed an application for a patent for the same invention in < 
foreign country which affords similar privileges in the case of applications filed in the United States or to 
citizens of the United States, shall have the same effect as the same application would have if filed in this 
country on the date on which the application for patent for the same invention was first filed in such foreign 
country, if the apphcatwn in this country is filed within twelve months from the earliest date on which such 



4474S<5_1 



-5- 



foreign application was filed; but no patent shall be granted on any application for patent for an invention which 
had been patented or described in a printed publication in any country more than one year before the date of he 
actual filing of the application in this country, or which had been in public use or on sale in this country more 
than one year prior to such filing. 



Title 35. U.S. Code. S 170 

Benefit or earlier filing date in the United States 

An application for patent for an invention disclosed in the manner provided by the first paragraph of 
section 1 12 of this title in an application previously filed in the United States, or as provided by section 363 of 
this title, which is filed by an inventor or inventors named in the previously filed application shall have the same 
effect, as to such invention, as though filed on the date of the prior application, if filed before the patenting or 
abandonment of or termination of proceedings on the first application or an application similarly entitled to the 
benefit of the filing date of the first application and if it contains or is amended to contain a specific reference to 
the earlier filed application. 

Please read carefully before signing the Declaration attached to the accompanying Application. 
If you have any questions, please contact Morgan & Finnegan, L.L.P. 
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